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(57) Abstract 

The invention relates to a bus system produced by concentrating individual conductors or buses within a unit of the type DFP, FPGA, 
DPGA, as well as all units with two- or multi-dimensionally programmable cell structure, and via which the units can be assembled to 
form several and/or can be connected to a memory and/or a periphery. 



(57) Zusammenfassung 

Es wird ein Bussystem vorgeschlagen, das durch Bundelung mehrerer einzelner Leitungen oder Busse oder Teilbusse innerhalb eines 
Bausteines der Gattung DFP, FPGA, DPGA, sowie alien Bausteinen mit zwei- oder mehrdimensionaler programmierbarer Zellstruktur 
hergestellt ist, und iiber welches die Bausteine zu Mehreren zusammengefaBt werden kSnnen und/oder Speicher und/oder Peripherie 
anschlieBbar sind/ist. 
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10- und Speicherbussystem fur DFPs sowie Bausteine mit zwei- 
oder mehrdimensionalen programmierbaren Zellstrukturen 

1. Hintergrund der Erfindung 
1.1 Stand der Technik 

1.1.1 ... in DFP-basierenden Systemen 

In DFPs gemaft DE 44 16 881 Al werden die Leitungen jeder 
Kantenzelle, das ist eine Zelle, die sich am Rand eines 
Zellarrays befindet und oftmals direktet Kontakt mit den 
Anschliissen des Bausteines haben kann, uber die Anschliisse des 
Bausteines herausgef iihrt . Dabei haben die Leitungen keine 
spezielle Funktion, vielmehr iibernehmen sie die Funktion, die in 
den Kantenzellen beschrieben , ist . Werden mehrere DFPs miteinander 
vernetzt, so werden alle Anschliisse zu einer Matrix miteinander 
verbunden. 

1.1.2 ... in Systemen mit zwei- oder mehrdimensionalen 
programmierbaren Zellstrukturen (FPGAs, DPGAs) 

In Systemen mit zwei- oder mehrdimensionalen programmierbaren 
Zellstrukturen (FPGAs, DPGAs) wird eine bestimmte Teilmenge von 
internen Bussystemen und Leitungen der Kantenzellen uber die 
Anschliisse des Bausteines herausgef iihrt . Dabei haben die 
Leitungen keine spezielle Funktion, vielmehr iibernehmen sie die 
Funktion, die in den Kantenzellen beschrieben ist. Werden mehrere 
FPGAs/DPGAs miteinander vernetzt, so iibernehmen die Anschliisse 
die Funktion, die hardware oder sof twareseitig implementiert 
wurde . 
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1.2 Probleme 

1.2.1 ... in DFP-basierenden Systemen 

Der Verdrahtungsaufwand fiir die Peripherie oder Vernetzung von 
DFPs ist sehr hoch. Da gleichzeitig der Programmierer dafiir zu 
sorgen hat, daft die entsprechenden Funktionen in die Zellen 
des/der DFPs integriert werden. Zum Anschlull eines Speichers muft 
eine Speicherverwaltung in den Baustein integriert werden. Zum 
Anschluli von Peripherie muft diese untersttitzt werden, ebenso wie 
die Kaskadierung von DFPs entsprechend berucksichtigt werden mufl. 
Der Aufwand ist verhaltnismaflig hoch, gleichzeitig geht Flache 
auf dem Baustein fiir die jeweiligen Implementierungen verloren. 

1.2.2 ... in Systemen mit zwei- oder mehrdimensionalen 
programmierbaren Zellstrukturen (FPGAs, DPGAs) 

Oben beschriebenes gilt ebenfalls fur FPGAs und DPGAs, ins 
besondere, wenn diese zur Implementierung von Algorithmen 
eingesetzt werden und als numerische (Co) Prozessoren arbeiten. 

1.3 Verbesserung durch die Erfindung, Aufgabe 

Der Verdrahtungsaufwand, ins besondere die Anzahl der 
Bausteinanschlilsse wird erheblich reduziert. Ein einheitliches 
Bussystem arbeitet ohne besondere Rucksichtnahme durch den 
Programmierer. Die Steuerung des Bussystems ist fest 
implementiert . Ohne besondere Maftnahmen kann an das Bussystem 
Speicher, sowie Peripherie angeschlossen werden. Ebenfalls konnen 
Bausteine mit Hilfe das Bussystems kaskadiert werden. 

2. Beschreibung der Erfindung 

2.1 Ubersicht iiber die Erfindung, Abstrakt 

Die Erfindung beschreibt ein allgemeines Bussystem, das eine 
Vielzahl bausteininterner Leitungen zusammenf alit und als Biindel 
an die Anschliisse herausfiihrt. Die Steuerung des Bussystems ist 
dabei vordefiniert und bedarf. keines Einflusses durch den 
Programmierer. An das Bussystem lassen sich beliebig Speicher, 
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Peripherie oder weitere Bausteine zur Kas kadierung anschl ieften . 
Die Einzelheiten und besondere Ausgestaltungen, sowie Merkmale 
des erf indungsgemalien Bussystems sind Gegenstand der 
Patentanspruche . 

2.2 Detailbeschreibung der Erfindung 

Die nachfolgende Beschreibung umfalit mehrere Strukturen, die wie 
bei DFPs, FPGAs, DPGAs, o.a. ublich von einer Ladelogik aus 
gesteuert und konfiguriert werden. Dabei konnen Teile der 
Ladelogik auf dem Baustein integriert sein. Alternativ besteht 
die Mbglichkeit (Fig. 6/7) die Strukturen durch den Baustein 
selbst direkt dynamisch umzukonf igurieren oder zu steuern. Dabei 
konnen die Strukturen fest auf dem Baustein implementiert sein, 
oder erst durch Konf iguration und moglicherweise Zusammenschluft 
mehrere Logikzellen, das sind konf igurierbare Zelleen, die 
einfache logische ode arithmetische Aufgaben gemaft ihrer 
Konf iguration erfullen (vgl. DFP, FPGA, DPGA) , entstehen. 

2.2.1 Biindelung interner Leitungen} 

Um sinnvolle Busstrukturen zu erhalten, wird eine Mehrzahl 
interner Leitungen wird zu Bussen (I-BUSn; n gibt die Nummer des 
Busses an) zusammengef aftt . Dabei kann es sich bei den Leitungen 
um interne Bussysteme oder um Leitungen der Kantenzellen handeln. 
Die einzelnen Busse werden fur Schreibzugrif f e auf den externen 
Bus (E-BUS) uber taktsynchrone Latche oder Register (I-GATE-REG) 
auf Tore gefuhrt, die als Schalter zum E-BUS arbeiten. Eine 
derartige Einheit wird Ausgabezelle (OUTPUT-CELL) genannt. Der 
Zugriff auf den E-BUS geschieht derart, daft die einzelnen Latche 
uber die Tore auf den gemeinsamen E-BUS geschaltet werden. Dabei 
ist immer nur ein Tor geoffnet. Jeder I-BUSn besitzt eine 
eindeutige Kennummer (n: z.B. I-BUS1, I-BUS976, ...). 
Fiir Lesezugriffe wird der hereinf iihrende E-BUS in taktsynchrone 
Latche oder Register (E-GATE-REG) zwischengespeichert und dann 
uber die Tore an die I-BUSn verteilt . Eine derartige Einheit wird 
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Eingabezelle (INPUT-CELL) genannt. Der Abgriff vom E-BUS 
geschieht dabei derart, daft ein E-BUS-Transf er in ein oder 
mehrere E-GATE-REG geschrieben wird. Die E-GATE-REG konnen dann 
entweder einzeln oder gemeinsam auf ihre internen Bussysteme 
f reigeschaltet werden. 

Dabei konnen die Schreib-/Lesezugrif f e in beliebiger Reihenfolge 
ablaufen. Es ist unter Umstanden sinnvoll die internen Busse I- 
BUSn in zwei Gruppen zu unterteilen, die schreibenden 
Ausgabebusse IO-BUSn und die lesenden Eingabebusse II-BUSn. 

2.2.2 Adressgenerierung 

Fur die meisten Zugriffe auf externe Bausteine ist es notwendig 
Adressen zur Auswahl eines Bausteines oder Teilen eines 
Bausteines zu generieren. Dabei konnen die Adressen fest sein, 
das heiftt sie andern sich nicht (dies ist vor allem bei 
Peripherieadressen der Fall) oder die Adressen verandern sich bei 
jedem Zugriff um (meist) feste Werte (dies ist vor allem bei 
Speicheradresssen der Fall). ,Zur Generierung der Adressen 
existieren programmierbare Zahler fur die Lesezugriffe und 
programmierbare Zahler fur die Schreibzugrif f e . Die Zahler werden 
durch die Ladelogik, das ist die Einheit, die die, auf einer 
Zellstruktur basierenden konf igurierbaren Bausteine (DFPs, FPGAs, 
DPGAs o.a.) konf iguriert , auf einen Grundwert eingestellt. Bei 
jedem Zugriff auf das Tor zahlt der Zahler je nach Einstellung um 
einen von der Ladelogik festgelegten Wert nach oben oder unten. 
Ebenfalls kann jeder Zahler als Register verwendet werden, das 
bedeutet, bei einem Zugriff wird nicht gezahlt, der im Zahler 
eingestellte Wert ist statisch. Jedem Bustransfer wird als 
Adresse der Wert des zum Tor gehorenden Zahlers zugeordnet. Die 
Einstellung des Zahlers geschieht uber ein Einstellungsregister 
(MODE-PLUREG) , das von der Ladelogik beschrieben wird. 
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2.2.3 Masken und Zustande 

Jedem Tor ist eine Anzahl Bits im spacer beschriebenen MODE- 
PLUREG zugeordnet, die angibt, ob der Tor aktiv ist oder von der 
Steuerung ubergangen wird, also ausmaskiert ist (MASKE) . Das 
bedeutet, der Tor wird beim Durchlaufen aller Tor zum Aufschalten 
auf das jeweilige Bussystem ubergangen. 
Folgende Masken-Eintrage sind denkbar: 

- INPUT- /OUT PUT-CELL immer ubergehen 

- IN PUT- /OUT PUT-CELL nur beim Schreiben Ubergehen 

- INPUT- /OUT PUT-CELL nur beim Lesen ubergehen, wenn der E-BUS- 
MAS\-TER nicht auf die INPUT- /OUTPUT-CELL zugegriffen hat 

- INPUT- /OUTPUT-CELL niemals ubergehen 

Jedem Tor ist ein Zustandsregister, das als RS-Flipflop 
ausgestaltet sein kann, zugeordnet. Dieses Register zeigt an, ob 
Daten in das zum Tor gehorenden Register geschrieben wurden. 

2.2.4 Das MODE-PLUREG 

Das MODE-PLUREG kann von der Ladelogik beschrieben und gelesen 
werden. Es dient zur Einstellung des Bussystems. 



Ein mSglicher Aufbau des MODE-PLUREG aus Sicht der Ladelogik 



Bit 1 . .m 


Bit k. . 1 


Bit 2. .k 


Bit 1 


Bit 0 


Maske 


Vor- 

def inierter 
Wert 


Schrittbreite 


0=additiv 
zahlen 

l=subtraktiv 
zahlen 


0=Register 
l=Zahler 


maskieren 


Einstellungen fur Adressgenerator 
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2.2.5 Beschreibung der INPUT-CELL 

Es wird unterschieden, ob Daten vom E-BUS in den Baustein 
gelangen (die dafur notwendige Einheit wird INPUT-CELL genannt) 
Oder ob Daten aus dem Baustein auf den E-BUS gelangen (die dafur 
notwendige Einheit wird OUTPUT-CELL genannt). 

Eine INPUT-CELL kann wie folgt ausgestaltet sein: Ein Latch (I- 
GATE-REG) , das entweder vom externen E-BUS-MASTER Oder der 
bausteineigenen Zustandsmaschine gesteuert wird, dient zur 
Zwischenspeicherung der Daten, die vom ErBUS erhalten werden. 
Dabei ist das Taktsignal des Latches an ein (z.B.) RS-Flipflop 
(SET-REG) gefuhrt, das den Zugriff auf das I-GATE-REG festhalt. 
Hinter dem I-GATE-REG befindet sich ein Tor ( I -GATE) , das von der 
Zustandsmaschine gesteuert wird.Uber das I -GATE gelangen die 
Daten aus dem I-GATE-REG auf den I(I)-BUSn. 

Des weiteren befindet sich ein programmierbarer auf/abwarts- 
ZShler in der INPUT-CELL. Er kann nach jedem aktiven Lesezugriff 
auf den E-BUS durch die Zustandsmaschine gesteuert, urn einen 
einstellbaren Wert hoch- oder herunterzahlen . Ebenfalls kann er 
als einfaches Register dienen. Dieser Zahler generiert die 
Adressen fur Buszugriffe, in denen der Baustein E-BUS-MASTER ist. 
Die Adressen werden durch ein Tor (ADR-GATE) auf den E-BUS 
gefuhrt. 

Das ADR-REG wird von der Zustandsmaschine gesteuert. 

Uber ein weiteres Tor (STATE-GATE) kann der E-BUS-MASTER den 
Zustand des SET-REG abfragen. Jede INPUT-CELL besitzt ein MODE- 
PLUREG, in dem die Ladelogik den Zahler konfiguriert und die 
INPUT-CELL aus- oder einschaltet (maskiert) . 
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2.2.6 Beschreibung der OUTPUT-CELL 

Eine OUTPUT-CELL kann wie folgt ausgestaltet sein: Ein Latch (E- 
GATE-REG) , das von der bausteineigenen Zustandsmaschine gesteuert 
wird, dient zur Zwischenspeicherung der Daten, die vom I-BUS 
erhalten werden. 

Des weiteren befindet sich ein programmierbarer auf/abwarts- 
Zahler in der OUT-PUT-CELL. Dabei ist das Taktsignal des Latches 
an ein (z.B.) RS-Flipflop (SET-REG) gefuhrt, das den Zugriff auf 
das E-GATE-REG festhalt. Er kann nach jedem aktiven Lesezugriff 
auf den E-BUS durch die Zustandsmaschine gesteuert, urn einen 
einstellbaren Wert hoch- oder herunterzahlen . Ebenfalls kann er 
als einfaches Register dienen. Dieser Zahler generiert die 
Adressen fur Buszugriffe, in denen der Baustein E-BUS-MASTER ist. 

Die Daten des E-GATE-REG, die Adressen und der Zustand des SET- 
REG werden uber ein Tor (E-GATE) , das entweder vom externen E- 
BUS-MASTER oder der bausteineigenen Zustandsmaschine gesteuert 
wird, auf den gefuhrt. Jede OUTPUT-CELL besitzt ein MODE-PLUREG, 
in dem die Ladelogik den Zahler konfiguriert und die OUTPUT-CELL 
aus- oder einschaltet (maskiert) . 

2.2.7 Steuerung des Bussystems 

Den einzelnen Toren, Adressgeneratoren und Masken ist eine 
Steuerung ubergeordnet . Diese besteht aus einer einfachen 
Zustandsmaschine nach dem Stand der Technik. Dabei werden zwei 
Betriebsarten unterscheiden : 

1. Eine Aktive, in der die Zustandsmaschine den internen Bus (I- 
BUS) und den externen Bus (E-BUS) steuert. Diese Betriebsart 
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wird E-BUS-MASTER genannt, da die Zustandsmaschine die 
Kontrolle Uber den E-BUS besitzt. 
2. Eine Passive, in der die Zustandsmaschine nur den internen Bus 
(I-BUS) steuert. Der E-BUS wird von einem anderen externen 
Baustein kontrolliert . Die Zustandsmaschine reagiert in dieser 
Betriebsart auf die Anf orderungen des externen E-BUS-MASTERS . 
Diese Betriebsart wird E-BUS-SLAVE genannt. 

Die Steuerung verwaltet das E-BUS Protokoll. Dabei ist der Ablauf 
unterschiedlich, je nachdem, ob die Steuerung als E-BUS-MASTER 
Oder E-BUS-SLAVE arbeitet. Ein Busprotokoll wird in dieser 
Schrift nicht beschrieben, da eine Vielzahl von Protokollen nach 
dem Stand der Technik implementiert werden konnen. 

2.2.8 E-BUS-MASTER und E-BUS-SLAVE, das EB-REG 

Zur Verwaltung des Datenver kehrs auf dem E-BUS existiert das E- 
BUS-Steuerregister (EB-REG) . Es ist in Reihe mit den Toren 
geschaltet und kann vom E-BUS aus adressiert und angesprochen 
werden. Uber folgende Eintrage konnte der Datenaustausch geregelt 
werden: 

I-WRITE: zeigt an, daft der I-BUS komplett in die INPUT-/OUTPUT- 

CELLs geschrieben ist 
I -READ : zeigt an, daB der I-BUS die INPUT-/OUTPUT-CELLs komplett 

gelesen hat 

E -WRITE : zeigt an, daft der E-BUS komplett in die IN PUT- /OUTPUT - 

CELLs geschrieben ist 
E-READ : zeigt an, daft der E-BUS die INPUT-/OUTPUT-CELLs komplett 
gelesen hat 
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Das EB-REG ist immer nur auf der Seite des E-BUS-SLAVE aktiv und 
der E-BUS-MASTER greift lesend und schreibend darauf zu. 

- Alle I- ... -Eintrage werden vom E-BUS-SLAVE geschrieben und vom 
E-BUS-MASTER gelesen. 

- Alle E- ... -Eintrage werden vom E-BUS-MASTER geschrieben und vom 
E-BUS-SLAVE gelesen. 

Ein E-BUS-SLAVE kann die Kontrolle uber den E-BUS fordern, in dem 
er das Bit REQ-MASTER in seinem EB-REG setzt. Erkennt der E-BUS- 
MASTER das Bit REQ-MASTER, so muft er seine Buskontrolle so bald 
wie moglich abgeben. Dies geschieht, in dem er das Bit MASTER im 
EB-REG eines E-BUS-SLAVE setzt. Er schaltet darauf hin sofort die 
E-BUS passiv. Der alte E-BUS-SLAVE wird zum neuen E-BUS-MASTER 
und der alte E-BUS-MASTER wird zum neuen E-BUS-SLAVE. Der neue E- 
BUS-MASTER ubernimmt die Steuerung des E-BUS. Zur Erkennung des 
ersten E-BUS-MASTERs nach einer Rucksetzung (RESET) des Systems, 
existiert ein Anschlufr an jedem Baustein, der durch die 
voreingestellte Polaritat angibt, ob der Baustein nach 
einem RESET E-BUS-MASTER oder E-BUS-SLAVE ist. Der Eintrag MASTER 
im EB-REG kann auch von der Ladelogik gesetzt und zuruckgesetzt 
werden. Dabei hat die Ladelogik darauf zu achten, daft keinerlei 
Buskollisionen am EB-BUS entstehen oder laufende 
Transfers abgebrochen werden. 

2.2.9 E-BUS-MASTER schreibt Daten in E-BUS-SLAVE 

Folgendermafien kann der E-BUS-MASTER Daten in den E-BUS-SLAVE 
schreiben: 
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Die Dateniibertragung beginnt damit, daft die Zustandsmaschine 
des E- BUS -MASTERS eine OUTPUT-CELL auswahlt, die nicht 
ausmaskiert ist. 
=> Im I-GATE-REG sind, je nach Ausfuhrung der Zustandsmaschine, 
bereits Daten gespeichert oder die Daten werden jetzt 
gespeichert . 
=i> Das Tor wird aktiviert. 

-> Die giiltige Leseadresse wird auf den Bus iibertragen. 
-» Die Daten gelangen auf den E-BUS und werden in das E-GATE- 
REG des E-BUS-SLAVE gespeichert. 

=> Dadurch wird das SET-REG im E-BUS-SLAVE aktiviert. 

=> Das Tor im E-BUS-MASTER wird deaktiviert. 

=> Der Adresszahler generiert die Adresse fur den nachsten 

Zugrif f . 

=> Der Transfer ist fur den E-BUS-MASTER beendet. 
Auf der Seite des E-BUS-SLAVE existieren zwei 

Ausgestaltungsmdglichkeiten die Daten vom Bus in den Baustein 
zu transf erieren : 

1. Das Daten-Tor ist immer of fen und die Daten gelangen direkt 
vom E-GATE-REG auf den I-BUSn. 

2. Die Zustandsmaschine erkennt, daft SET-REG aktiviert ist und 
aktiviert das Tor, dadurch kann SET-REG zuruckgesetzt werden. 

Der E-BUS-MASTER kann dem E-BUS-SLAVE mitteilen, wann ein 
kompletter Buszyklus beendet ist. (Ein Buszyklus ist als das 
Obertragen mehrerer Datenworte an unterschiedliche E-GATE-REG 
definiert, wobei jedes E-GATE-REG genau ein Mai angesprochen 
werden darf . ) 
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=> Dazu setzt der E- BUS -MASTER am Ende eines Buszyklus das Bit E- 

WRITE im EB-REG des E-BUS-SLAVE. 
=> Der E-BUS-SLAVE kann darauf reagieren, in dem er die INPUT- 
CELLs abfragt. 

=> Hat er alle INPUT-CELLs abgearbeitet, setzt er das Bit I-READ 

in seinem EB-REG. 
=> Dabei setzt er E-WRITE und samtliche SET-REG der INPUT-CELLs 
zuruck . 

=> Der E-BUS-MASTER kann I-READ abfragen und nach dessen 

Aktivierung einen neuen Buszyklus beginnen. 
=> I-READ wird durch Schreiben von E-WRITE oder den ersten 

Bustransfer zuriickgesetzt . 

Der E-BUS-SLAVE kann anhand des Zustandes des EB-REG oder der 
einzelnen SET-REG der INPUT-CELLs auswerten, ob die INPUT-CELLs 
neu gelesen werden konnen/mussen . 

2.2.10 E-BUS-MASTER liest Daten von E-BUS-SLAVE 

Aus der Sicht des E-BUS-MASTERs existieren zwei grundlegende 
Methoden Daten vom E-BUS-SLAVE zu lesen: 

1. Verfahren, in dem die E-BUS-Daten direkt auf den I-BUS 
gelangen : 

=> Die Datenubertragung beginnt damit, da 15 die Zustandsmaschine 
des E-BUS-MASTERs eine INPUT-CELL auswahlt, die nicht 
ausmaskiert ist. 

=> Das I -GATE und das ADR-GATE werden aktiviert. 
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-» Die gultige Leseadress'e wird auf den Bus ubertragen. 

=> Das I-GATE-REG ist transparent, d.h. es lafit die Daten auf den 
I-BUSn durch. 

=> Das Tor im E-BUS-MASTER wird deaktiviert. 

=> Der Adresszahler generiert die Adresse fur den nachsten 

Zugrif f . 

=> Der Transfer ist fur den E-BUS-MASTER beendet. 

2. Verfahren, in dem die E-BUS-Daten im I-GATE-REG 
zwischengespeichert werden: 

=> Die Datenubertragung beginnt damit, dali die Zustandsmaschine 
des E-BUS-MASTERs eine INPUT-CELL auswahlt, die nicht 
ausmaskiert ist. 

=> Das I -GATE und das ADR-GATE werden aktiviert. 

-> Die gultige Leseadresse wird auf den Bus ubertragen. 

=> Das I-GATE-REG speichert die Daten. 

=> Das Tor im E-BUS-MASTER wird deaktiviert. 

=> Der Adresszahler generiert die Adresse fur den nachsten 
Zugrif f. 

=> Der E-BUS-Transf er ist fur den E-BUS-MASTER beendet. 

=> Alle am E-BUS-Transf er beteiligten INPUT-CELLs, dies kann 

anhand der Masken in den MODE-PLUREG Oder dem Zustand der SET- 
REG festgestellt werden, werden durchlaufen und die Daten auf 
den jeweiligen I-BUS ubertragen. 

Fur den E-BUS-SLAVE sieht der Zugrif f wie folgt aus: 
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=> Durch den E-BUS wird das Tor aktiviert. 

Die Daten und der Zustand des moglicherweise vorhandenen SET- 
REG gelangen auf den E-BUS. 

=> Das Tor wird deaktiviert. 

Der E-BUS-MASTER kann dem E-BUS-SLAVE mitteilen, wann ein 
kompletter Buszyklus beendet ist. 

=>Dazu setzt der E-BUS-MASTER am Ende eines Buszyklus das Bit E 
READ im EB-REG des E-BUS-SLAVE. 

=>Der E-BUS-SLAVE kann darauf reagieren, in dem er die OUTPUT- 
CELLs neu beschreibt. 

=>Hat er alle OUTPUT-CELLs abgearbeitet, setzt er das Bit I-WRI 
in seinem EB-REG. 

=>Dabei setzt er E-READ und samtliche SET-REG der OUTPUT-CELLs 
zuriick. 

=>Der E-BUS-MASTER kann I-WRITE abfragen und nach dessen 

Aktivierung einen neuen Buszyklus beginnen. 
=>I-WRITE wird durch Schreiben von E-READ oder den ersten 

Bustransfer zuruckgesetzt . 

Der E-BUS-SLAVE kann anhand des Zustandes des EB-REG oder der 
einzelnen SET-REG der OUTPUT-CELLs auswerten, ob die OUTPUT- 
CELLs neu beschrieben werden konnen/mussen . 

2.2.11 AnschluU von Speicher, Peripherie und Kaskadierung 

AuJJer der Kaskadierung von gleichen Bausteinen (DFPs, FPGAs, 
DPGAs) kann an das beschriebene Bussystem Speicher und Periphery 
als untergeordnete SLAVE-Baustein (SLAVE) angeschlossen werden. 



13 



WO 98/28697 PCT/DE97/03013 



Dabei kann Speicher und Peripherie, sowie weitere Bausteine 
(DFPs, FPGAs) gemischt werden-. Jeder angeschlossene SLAVE wertet 
die Adressen auf dem Bus aus und erkennt selbstandig ob er 
angesprochen ist. In diesen Betriebsarten ist der Baustein, der 
den Speicher oder die Peripherie, also die SLAVE-Bausteine 
anspricht, der Bus-MASTER (MASTER), d.h. der Baustein steuert den 
Bus und den Datentransf er . Die Ausnahme bilden intelligente 
Peripheriebausteine, wie z.B. SCSI-Kontroller , die selbstandig 
Transfers initieren und durchfuhren kdnnen und daher E-BUS-MASTER 
sind. 



2.2.12 Zusammenf assung 

Durch das beschriebene Verfahren, lassen sich Bussysteme einfach 
und leistungsfahig an DFPs und FPGAs anschliellen . Dabei konnen 
uber die Bussysteme sowohl Speicher und Peripherie, als auch 
weitere Bausteine o.g. Gattung verbunden werden. 

Das Bussystem muJ3 nicht ausschlieMich in den DFPs, FPGAs und 
DPGAs implemetiert sein. Selbstverstandlich ist ein Mischbetrieb 
dieses Bussystemes mit den herkommlichen Anschlutistrukturen der 
Bausteinemoglich . Damit konnen die Vorteile der jeweiligen 
Technik optimal genutzt werden. 

Es sind weitere Ablauf verfahren fUr das beschriebene Bussystem 
denkbar. Diese werden jedoch nicht beschrieben, da es sich urn 
freie Ausgestaltungsmoglichkeiten handelt, die vom hier 
auf zuzeigenden Grundprinzip unabhangig sind. 
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3 Kurzbeschreibung der Diagramme 



Figur 


± 


7a-i ^Krnnn a i noc Raci chanQtPi riPQ FPf^I A Tvn A 


Figur* 


o 

t. ■ 


7oi nhnnnn pi np<; «i "i «i hfl n s 1" f=» 1 n f=» *=» ri 1 S FPGA TvD B 


c j. y li i. 




7.pi rhnnnn pi npq Ra £5 i ^bau s t nps als DFP 






T o*i t" unrr c;hiinHp 1 n n n "i n F P G A 


I 1UUI 




T oi t"nnn<5hiinHpl urin "in 0 F P c; 


c lyui 


o • 


Pi no nriTPMT — TFT T 


L 1^ Ui 


7 


Pino TMPnT-PFT T. 
Line i in r u i \^ l-ixj±j 


Figur 


8 : 


Die Adressaener ieruna 
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Komplettes Bussystem mit Steuerung 


Figur 
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AnschluJi von Speicher und Peripherie 
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Das EB-REG 
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Ausf tlhrungsbei spiel 
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Ausf iihrungsbeispiel 2 
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Bus-IO des zweiten Ausf uhrungsbeispiels 
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15a: 


Adress-Generator des weiten Ausf uhrungsbeispiels 


Figur 


15b: 


Alternativer Adress-Generator der eine End-of-Data 
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15c: 


Funktionsablauf beim Adress-Generator mit End-of-D 
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16 : 


Zusammenspiel zweier Segmente bei der indirekten 






Adressierung . 


Figur 


17 : 


Die State-Machine fur die indirekte Adressierung 



4 Detailbeschreibung der Diagramme 

Figur 1 zeigt einen FPGA nach dem Stand der Technik. 0101 stellt 
die internen Bussysteme dar, 0102 beinhaltet eine oder mehrer 
FPGA-Zelle (n) . 0103 sind Teilbusse, die eine Teilmenge von 0101 
darstellen und uber Schalter (Crossbars) mit 0101 verbunden sind. 
0103 kann auch interne Daten von 0102 verwalten, die nicht auf 
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0101 geschaltet werden. Die FPGA-Zellen sind in einem 2- 
dimensionalen Array angeordnet. 

0104 stellt eine Kantenzelle dar, die am Rand des Arrays sitzt 
und sich somit in nachster Nahe zu den Anschlussen am Rand des 
Bausteins befindet. 

Figur 2 zeigt einen weiteren FPGA nach dem Stand der Technik. 
Diese Ausf uhrungsmoglichkeit arbeitet nicht mit Bussystemen wie 
0101 sondern hauptsachlich mit Next-Neighbour-Verbindungen 

(0201) , das sind direkte Verbindungen von einer FPGA-Zelle (0203) 
zu ihrer Nachbarzelle . Es kdnnen dennoch globale Bussysteme 

(0202) existieren, diese sind jedoch nicht sehr breit.Die F-PGA- 
Zellen oder eine Gruppe von FPGA-Zellen besitzen eine Verbindung 
zu 0202. Die FPGA-Zellen sind in einem 2-dimensionalen Array 
angeordnet. 0204 stellt eine Kantenzelle dar, die am Rand des 
Arrays sitzt und sich somit in nachster Nahe zu den Anschlussen 
am Rand des Bausteins befindet. 

Figur 3 zeigt einen DFP nach DE 196 51 075.9. Dabei sind die PAE- 
Zellen (0303) uber ein Businterface (0304) auf die Bussysteme 
(0301) geschaltet. Die Bussysteme 0301 kdnnen uber einen 
Busschalter (0302) miteinander verschaltet werden. Die PAE-Zellen 
sind in einem 2-dimensionalen Array angeordnet. 0305 stellt eine 
Kantenzelle dar, die am Rand des Arrays sitzt und sich somit in 
nachster Nahe zu den Anschlussen am Rand des Bausteins befindet. 

Figur 4a zeigt eine FPGA-Kante nach Figur 1. AuGerhalb der 
Kantenzellen (0401) ist eine Mehrzahl von INPUT-/OUTPUT-CELLS 
(0402) angeordnet, die zu mehreren oder einzeln die internen 
Bussysteme (0403) mit dem E-BUS (0404) verbinden. Dabei ist die 
Menge der INPUT-/OUTPUT-CELLs von ihrer eigenen Breite im 
Verhaltnis zur Breite der internen Bussysteme abhangig. 0405 
stellt ein EB-REG dar. 0406 stellt eine Zustandsmaschine dar. Von 
der Zustandsmaschine geht zum EB-REG und jeder einzelnen INPUT- 
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/OUTPUT-CELL ein Bussystem (0407), uber das die Zustandsmaschine 
die INPUT-/OUTPUT-CELLs steuert. Dabei konnen mehrere 0405 und 
0406 existieren, indem je eine Menge an 0402 zu Gruppen 
zusammengefalit werden und von je einer 0405 und 0406 verwaltet 
werden . 

Figur 4b zeigt eine FPGA-Kante nach Figur 2. AulJerhalb der 
Kantenzellen (0411) ist eine Mehrzahl von INPUT-/OUTPUT-CELLs 
(0412) angeordnet, die zu mehreren oder einzeln die internen 
Bussysteme (0413) und die direkten Verbindungen der Kantenzellen 
(0417) mit dem E-BUS (0414) verbinden. Dabei ist die Menge der 
INPUT- /OUT PUT-CELLs von ihrer eigenen Breite im Verhaltnis zur 
Breite der internen Bussysteme (0413) und der Menge der direkten 
Verbindungen (0418) abhangig. 0415 stellt ein EB-REG dar. 0416 
stellt eine Zustandsmaschine dar. Von der Zustandsmaschine geht 
zum EB-REG und jeder einzelnen INPUT-/OUTPUT-CELL ein Bussystem 
(0417), uber das die Zustandsmaschine die INPUT-/OUTPUT-CELLs 
steuert. 

Dabei konnen mehrere 0415 und 0416 existieren, indem je eine 
Menge an 0412 zu Gruppen zusammengef alit werden und von je einer 
0415 und 0416 verwaltet werden. 

Figur 5 zeigt eine DFP-Kante nach Figur 3. Aufierhalb der 
Kantenzellen (0501) ist eine Mehrzahl von INPUT-/OUTPUT-CELLs 
(0502) angeordnet, die zu mehreren oder einzeln die internen 
Bussysteme (0503) mit dem E-BUS (0504) verbinden. Dabei ist die 
Menge der INPUT-/OUTPUT-CELLs von ihrer eigenen Breite im 
Verhaltnis zur Breite der internen Bussysteme (0503) abhangig. 
0505 stellt ein EB-REG dar. 0506 stellt eine Zustandsmaschine 
dar. Von der Zustandsmaschine geht zum EB-REG und jeder einzelnen 
IN PUT- /OUT PUT-CELL ein Bussystem (0507), uber das die 
Zustandsmaschine die INPUT-/OUTPUT-CELLs steuert. Dabei konnen 
mehrere 0505 und 0506 existieren, indem je eine Menge an 0412 zu 
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Gruppen zusammengef aiit werden und von je einer 0505 und 0506 
verwaltet werden. 

Figur 6 zeigt eine OUTPUT-CELL 0601. Aulierhalb 0601 befindet sich 
das EB-REG (0602) und die Zustandsmaschine (0603), sowie ein Tor 

(0604) , das die Zustandsmaschine auf den E-BUS (0605) schaltet, 
sofern sie E-BUS-MASTER ist. Auf das EB-REG kann uber den E-BUS 

(0605) , den I-BUS (0613) und den Ladelogikbus (0609) zugegriffen 
werden . 

Weiterhin kann bei einem Riicksetzten des Bausteins (Reset) uber 
einen externen Anschluli (0614), der aus dem Baustein 
herausgefuhrt ist, das MASTER-Bit gesetzt werden. Die 
Zustandsmaschine (0603) greift schreibend und lesend auf 0602 zu. 
In der OUTPUT-CELL befindet sich ein Multiplexer (0606), der die 
Steuerung des E-GATE (0607) entweder dem E-BUS-MASTER oder der 
Zustandsmaschine (0603) zuordnet . 

Das MODE-PLUREG (0608) wird uber den Ladelogikbus (0609) oder den 
I-BUS (0613) eingestellt und . konf iguriert den Adresszahler 
(0610), sowie die Zustandsmaschine (z.B. ausmaskieren der OUTPUT- 
CELL) . Werden Daten des I-BUS (0613) in das I-GATE-REG (0611) 
gespeichert, wird der Zugriff im SET-REG (0612) vermerkt. Der 
Zustand von 0612 ist uber 0607 am E-BUS abfragbar. Ein lesender 
Zugriff (das E-GATE 0607 ist aktiviert) setzt 0612 zuruck. Die 
von 0610 generierten Adressen und die Daten von 0611 werden Uber 
das Tor 0607 auf den E-BUS ubertragen. Es besteht die Moglichkeit 
die OUTPUT-CELL statt uber die Ladelogik uber den Baustein (DFP, 
FPGA, DPGA, o.a". ) 

selbst dynamisch umzukonf igurieren und zu steuern. Hierzu dient 
der der I-BUS-AnschluA an das EB-REG (0602) und das MODE-PLUREG 
(0608) . 

Figur 7 zeigt eine INPUT-CELL 0701. Aulierhalb 0701 befindet sich 
das EB-REG (0702) und die Zustandsmaschine (0703), sowie ein Tor 
(MASTER-GATE) (0704), das die Zustandsmaschine auf den E-BUS 
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(0705) schaltet, sofern sie E-BUS-MASTER ist. Auf das EB-REG kann 
iiber den E-BUS (0705), den I -BUS (0713) und den Ladelogikbus 

(0709) zugegriffen werden. Weiterhin kann bei einem Rucksetzten 
des Bausteins (Reset) iiber einen externen Anschlufl (0714), der 
aus dem Baustein herausgef iihrt ist, das MASTER-Bit gesetzt 
werden. Die Zustandsmaschine (0703) greift schreibend und lesend 
auf 0702 zu. In der INPUT-CELL befindet sich ein Multiplexer 

(0706) , der die Steuerung des E-GATE-REG (0707) entweder dem E- 
BUS-MASTER oder der Zustandsmaschine (0703) zuordnet . Das MODE- 
PLUREG (0708) wird uber den Ladelogikbus (0709) oder den I-BUS 
(0713) eingestellt und konfiguriert den Adresszahler (0710), 
sowie die Zustandsmaschine (z.B. ausmaskieren der INPUT-CELL). 
Werden Daten des E-BUS (0705) in das E-GATE-REG (0707) 
gespeichert, wird der Zugriff im SET-REG (0712) vermerkt. 

Der Zustand von 0712 ist uber ein Tor (0715) , dessen Steuerung 
die selbe wie beim Latch (0707) ist, am E-BUS abfragbar. Ein 
lesender Zugriff, das E-GATE 0711 ist aktiviert und die Daten 
gelangen auf den I-BUS (0713), setzt 0712 uber 0717 zuruck. 
Alternativ kann 0712 uber die Zustandsmaschine (0703) 
zuriickgesetzt werden (0718) . 

Die von 0710 generierten Adressen werden uber das Tor (ADR-GATE) 
0716 auf den E-BUS ubertragen, 0716 wird von der Zustandsmaschine 
(0703) aktiviert, wenn diese E-BUS-MASTER ist. Es besteht die 
Moglichkeit die INPUT-CELL statt uber die Ladelogik iiber den 
Baustein (DFP, FPGA, DPGA, o.a.) selbst dynamisch 
umzukonf igurieren und zu steuern. Hierzu dient der der I-BUS- 
Anschlufi an das EB-REG (0702) und das MODE-PLUREG (0708) . 

Figur 8 zeigt das MODE-PLUREG (0801) einer INPUT- oder OUTPUT- 
CELL, das iiber den Ladelogikbus (0802) von der Ladelogik oder 
uber einen I-BUS (0808) beschrieben wird. 
Das jeweilige Bussystem wird uber den Multiplexer (0809) 
ausgewahlt, dabei ist die Steuerung des Multiplexers nicht 
eingezeichnet, da eine gewdhnliche Dekodierlogik verwendet werden 
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kann. Die Zahlereinstellungen, wie Schrittbreite, Zahlrichtung 
und Freischaltung des Zahlers werden direkt (0807) an den Zahler 

(0803) geleitet. Die Grundadresse kann entweder uber einen Load 

(0804) direkt in den Zahler geschrieben (0805) werden, oder in 
einera Zusatz (0811) zu 0801 zwischengespeichert werden. Die fur 
die Zustandsmaschine relevanten Eintrage in 0801 gelangen uber 
ein Tor (0806), das von der Zustandsmaschine fiir die jeweilig 
aktivierte INPUT- oder OUTPUT-CELL geoffnet wird, zur 
Zustandsmaschine . 

Figur 9a zeigt eine Businterf aceschaltung mit Zustandsmaschine 
(0901), MASTER-GATE (0902) und EB-REG (0903). Die INPUT-CELLs 
(0904) transferieren Daten vom E-BUS (0905) auf den II-BUS 
(0906) . Die OUTPUT-CELLs (0907) transferieren Daten vom IO-BUS 
(0908) auf den E-BUS (0905). Uber den Steuerbus (0909) sind 
samtliche Baugruppen miteinander verbunden. 

Figur 9b zeigt eine Businterf aceschaltung mit Zustandsmaschine 
(0901), MAS\-TER-GATE (0902) und EB-REG (0903). Die INPUT-CELLs 
(0904) transferieren Daten vom E-BUS (0905) auf den 
bidirektionalen I-BUS (0910). Die OUTPUT-CELLs (0907) 
transferieren Daten vom bidirektionalen I-BUS (0910) auf den E- 
BUS (0905). Uber den Steuerbus (0909) sind samtliche Baugruppen 
miteinander verbunden. Es sind auch Interf aceschaltungen denkbar, 
die beide Mbglichkeiten (Fig. 9a und 9b) gemischt 
verwenden . 

Figur 10a zeigt zwei Bausteine (DFPs, FPGAs, DPGAs, o.a.) (1001) 
iiber den E-BUS (1002) miteinander vernetzt. 

Figur 10b zeigt die Vernetzung einer Mehrzahl von Bausteinen 
(DFPs, FPGAs, DPGAs, o.a.) (1001) uber den E-BUS (1002). 
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Figur 10c zeigt die Vernetzung einer Mehrzahl von Bausteinen 
(DFPs, FPGAs, DPGAs, o.a.) (1001) Uber den E-BUS (1002). Die 
Vernetzung kann zu einer Matrix ausgebaut werden. Ein Baustein 
(1001) kann auch eine Mehrzahl von Bussystemen (1002) verwalten. 

Figur lOd zeigt die Vernetzung eine Bausteins (DFPs, FPGAs, 
DPGAs, o.a.) (1001) mit einem Speicherbaustein oder einer 
Speicherbank (1003) uber den E-BUS (1002). 

Figur lOe zeigt die Vernetzung eine Bausteins (DFPs, FPGAs, 
DPGAs, o.a.) (1001) mit einem Peripheriebaustein oder einer 
Peripheriegruppe (1004) uber den E-BUS (1002). 

Figur lOf zeigt die Vernetzung eine Bausteins (DFPs, FPGAs, 
DPGAs, o.a.) (1001) mit einem Speicherbaustein oder einer 
Speicherbank (1003) und mit einem Peripheriebaustein oder einer 
Peripheriegruppe (1004) iiber den E-BUS (1002). 

Figur lOg zeigt die Vernetzung eine Bausteins (DFPs, FPGAs, 
DPGAs, o.a.) (1001) mit einem Speicherbaustein oder einer 
Speicherbank (1003) und mit einem Peripheriebaustein oder einer 
Peripheriegruppe (1004) und einem weiteren Baustein (DFPs, FPGAs, 
DPGAs, o.a.) (1001) iiber den E-BUS (1002). 

Figur 11 zeigt den Aufbau des EB-REG. Die Bussysteme E-BUS 
(1103); Ladelogikbus (1104), uber welchen die Ladelogik Zugriff 
auf das EB-REG hat und der lokale interne Bus zwischen den INPUT- 
/OUTPUT-CELLs, der Zustandsmaschine und dem EB-REG (1105, vgl. 
0407, 0417, 0517), sowie mSglicherweise ein I-BUS (1114) werden 
auf einen Multiplexer (1106) gefuhrt. Der Multiplexer (1106) 
wahlt entweder einen der Busse oder die Ruckkopplung auf das 
Register (1108) aus und schaltet die Daten zum Eingang des 
Registers (1108) durch. Das MASTER-Bit wird getrennt uber den 
Multiplexer (1107) zum Register (1108) gefUhrt. Der Multiplexer 
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wird uber das RESET-Signal (1101) (Rucksetzen Oder Initialisieren 
des Bausteines) gesteuert. Liegt ein RESET an, so schaltet der 
Multiplexer (1107) das Signal eines externen Chipanschlusses 
(1102) auf den Eingang des Registers (1108) durch, andernfalls 
wird der Ausgang des Multiplexers (1106) auf den Eingang des 
Registers (1108) durchgeschaltet . Dadurch kann MASTER vorbelegt 
werden. Das Register (1108) wird tiber den Systemtakt (1112) 
getaktet. Der Inhalt des Registers (1108) wird uber ein Tor 
(1109, 1110, 1111, 1113) auf das jeweils lesend zugreifenden 
Bussystem (1103, 1104, 1105, 1114) geschaltet. 
Die Steuerung der Tore (1109, 1110, 1111, 1113), sowie des 
Multiplexers (1106) ist nicht eingezeichnet, da eine gewohnliche 
Dekodierlogik verwendet werden kann. 



5 Ausf iihrungsbeispiele 

Figur 12 zeigt ein Beispiel bei dem das Standardbussystems RAMBUS 
(1203) eingesetzt wird. Ein Baustein (DFPs, FPGAs, DPGAs, o.a.) 
(1201) ist uber das Bussystem (1203) mit weiteren Baugruppen 
(Speicher, Peripherie, weitere DFPs, FPGAs, DPGAs, o.a.) (1202) 

verbunden. Der Baustein (1201) kann unabhangig vom Bussystem 
(1203) weitere Anschlulileitungen (1204), z.B wie nach dem Stand 

der Technik ublich, zum Anschlufi beliebiger Schaltkreise 

aufweisen . 

Figur 13 zeigt ein Implementierungsbeispiel fur ein 10- und 
Speicherbussystem. 1310 bildet den Rambus, der die Rambus- 
Interface (1308) mit dem Rambus-Speicher verbindet. Das Rambus- 
Interface ist mit einem Cache-Ram (1306) verbunden. Dem Cache-Ram 
(1306) ist ein Tag-Ram (1307), sowie ein Cache-Controller (1305) 
zugeordnet. Mit Hilfe des Cache-Controllers und des Tag-Ram wird 
geprUft ob angeforderte Daten im Cache-Speicher vorhanden sind 
Oder ob sie aus dem externen Rambus-Speicher geladen werden 
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mussen. Gesteuert werden der Cache-Ram, der Cache-Controller und 
das Rambus-Interface von einer State-Machine (1304) . Der Cache 
wird nach dem Stand der Technik implementiert . 

Der Arbiter (1303) regelt den Zugriff der einzelnen Bussegmente 
auf die Cache-Ram und somit auch auf den externen Speicher. Bei 
diesem Implementierungsbeispiel kann auf acht Bussegmente 
zugegriffen werden. Jede Verbindung zu einem Bussegment (1309) 
besitzt eine Bus-IO (1301) und einen Address-Generator (1302) . 
Aulierdem ist jede Bus-IO noch mit dem Ladelogikbus (1307) 
verbunden, sowie mit einem internen Test-Bus (1311) . Jede n-te 
Bus-IO ist mit der (n+l)-ten Bus-IO verbunden, wobei fur n gilt n 
= {1,3,5,...}. Durch diese Vebindung kdnnen Daten, die von dem n-ten 
Adress-Generator aus dem Speicher angefordert wurden, vom (n+1)- 
ten Segment als Adresse fur einen Speicherzugrif f benutzt werden. 
Damit ist eine indirekte Adressierung des Speichers moglich. Der 
Wert des Zahlers (1509) des Segmentes n zeigt auf eine 
Speicherstelle im Ram. Die Daten aus dieser Speicherstelle werden 
zum Segment (n+1) ubertragen und dienen dort als Base-Adresse zur 
Adressierung des Speichers. 

Figur 14 zeigt die Bus-IO Einheit. Sie ist mit dem internen 
Bussystem (1406), dem Test-Bussystem (1408) sowie dem 
Ladelogikbus (1407) verbunden. Der Bus (1412) und der Bus (1413) 
dient zur Verbindung der n-ten Bus-IO mit der (n+1) -ten Bus 10. 
Das heilit der Bus (1413) ist nur bei jedem n-ten Segment und der 
Bus (1412) ist nur bei jedem (n+1) -ten Segment vorhanden. Dabei 
sendet die n-te Bus-IO Daten uber den Bus (1413) und die (n+l)-te 
Bus-IO empfangt diese Daten durch den Bus (1412) . Die Bussysteme 

(1406, 1407, 1412) werden uber die Tore (1401, 1402, 1403, 1411) 
auf den Bus (1409) geschaltet, der die Bus-IO mit dem Adress- 
Generator verbindet. Der Arbiter (1404) wahlt ein Bussystem 

(1406, 1407, 1412) zur Datenubertragung aus und gibt ein 
Steuersignal an die State-Machine (1405), die ihrerseits die Tore 

(1401, 1402, 1403, 1411) steuert. Aulierdem sendet die State- 
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Machine (1405) noch Steuersignale (1410) an den Adress-Generator 
und das Ram. 

Es gibt zwei Moglichkeiten : 

a) Segment n: Die State-Machine (1405) erhalt vom Adress- 
Generator ein Konf igurationssignal (1415), das festgelegt ob eine 
indirekte Adressierung erfolgen soli. Nach einem Read- Trigger- 
Signal (1416) vom internen Bus (1406) oder dem Ladelogikbus 
(1407) schaltet die State Machine (1405) das zugehorige Tor 
(1401, 1402, 1403, 1411) frei und erzeugt die Steuersignale 
(1410) . Die durch den ladbaren Auf/Ab-Zahler (1509) adressierte 
Speicherstelle wird ausgelesen. Die in der Ram Speicherstelle 
enthaltenen Daten, werden nicht zum Bus zuruckgeschickt, sondern 
durch den Bus (1413) zum (n+l)-ten Segment tibertragen und dienen 
dort als Base-Adresse zur Adressierung des Ram. Die State-Machine 
(1405) gibt ein Acknowledge Signal zur Synchronisation nach 
erhalt der Daten vom Ram an die State Machine (1414), die den 
Ablauf bei der indirekten Adressierung steuert. Diese State 
Machine (1414) wird im folgenden Ind-State-Machine genannt . Sie 
erzeugt alle benotigten Kontrollsignale und schickt diese zum 
nachf olgenden Segment (1413). 

b) Segment (n+1) : Durch den Bus (1412) empfangt das (n+l)-te 
Segment, die vom n-ten Segment ubertragenen Daten. Der Arbiter 
(1404) bekommt ein Write Signal und schickt seinerseits eine 
Anforderung an die State-Machine, die das Tor (1411) 

f reischaltet . Das Tor (1411) fiigt den Daten von 1412 die interne 
Adresse des Base-Adressen Eintrags zu, damit der Decoder (1502) 
die Base-Adressen-Latches f reischaltet . 

Figur 15a zeigt den Adress-Generator. Uber den Bus (1409) werden 
Daten und Adressinf ormationen von der Bus-IO in den Adress- 
Generator ubertragen. Der Bus (1410) iibertragt die 
Kontrollsignale CLK (1517, 1508) und das Output-Enable-Signal 
(1518), sowie die Steuersignale zum Ram (1519). Das Output- 
Enable-Signal (1518) schaltet die Tore (1503, 1515) frei. Tor 
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(1503) schaltet die Daten von Bus (1409) auf den Datenbus (1504) 
zum Ram. Das Tor (1515) schaltet die erzeugten Adressen auf den 
zum Ram fuhrenden Adress-Bus (1520) . 
Die Adressen werden auf folgende Art generiert: Im 
Adressgenerator gibt es vier Eintrage, die zur Adressgenerierung 
dienen. Jeder Eintrag wird in zwei Latches (1501) gespeichert, 
wobei ein Latch die hoherwertige Adresse und das andere Latch die 
niederwertige Adresse speichert. Der Base-Adressen Eintrag 
enthalt die Startadresse eines Speicherzugrif f s . Der Step-Width 
Eintrag wird im ladbaren Auf /Ab-Zahler (1509) zur Base-Adresse 
hinzuaddiert oder abgezogen. Die Funktion (Auf/Ab) des ladbaren 
Auf /Ab-Zahlers (1509) wird in einem Bit der Base-Adresse kodiert 
und zum ladbaren Auf /Ab-Zahler (1509) iibertragen. 
Im End-Adressen Eintrag wird die Endadresse gespeichert und in 
einem Bit kodiert, ob die Adressgenerierung beim Erreichen der 
Endadresse abbricht oder der End-Adressen Eintrag ignoriert wird. 
Soli bis zu einer Endadresse gezahlt werden, wird der Wert des 
End-Adress-Eintrages mit dem Ausgangswert des ladbaren Auf/Ab- 
Zahlers verglichen. Dies geschieht im Komparator (1510), der 
sobald die Endadresse erreicht oder iiberschritten ist, einen 
Highpegel erzeugt. Bei aktivem Enable-End-Address Signal (1507) 
gibt das UND-Gatter (1512) diesen Highpegel zum ODER-Gatter 
(1514), das dann ein Trigger-Signal (1521) zum Ladelogikbus 
weitergibt . 

Im Data-Count Eintrag steht die Anzahl der Datentransf ers und 
somit der zu berechnenden Adressen. Auch hier wird iiber ein Bit 
im Data-Count Eintrag festgelegt, ob diese Funktion aktiviert ist 
und das Enable-Data-Counter Signal (1506) zum UND-Gatter (1513) 
geleitet wird oder der Data-Count Eintrag ignoriert wird. Der 
Zahler (1505) iibernimmt den Wert des Data-Count Eintrags und 
dekrementiert ihn bei jedem Clockimpuls um Eins. Der Vergleicher 
(1511) vergleicht den Wert des Zahlers (1505) auf Null und gibt 
ein Signal zum UND-Gatter (1513) . Ist das Enable-Data-Counter 
Signal (1506) aktiv, wird das Signal des Komparators (1511) zum 
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ODER-Gatter (1514) geleitet und als Tigger-Signal (1521) zum 
Ladelogikbus geleitet. 

Bestandteil des Busses (1409) sind Steuersignale und Adressen fur 
den Decoder (1502), der eines der Latche (1501) entsprechend der 
Adresse auswahlt. Ober den Decoder (1502) lalit sich auch das 
Konf igurationsregister (1516) ansteuern, das festlegt ob das 
Segment fur indirekte Adressierung verwendet wird. Die Daten des 
Konf igurationsregisters werden uber die Verbindung (1415) zur Bus 
10 des Segments ubertragen. 

Figur 15b zeigt eine Abwandlung des Adress-Generators aus 
Figurl5a, der am Anfang eines Datenblocks im Speicher, die 
Endadresse des Datenblocks ablegt. Der Vorteil dieser Ausfiihrung 
besteht darin, daft variabler GroBe des Datenblocks, das Ende fur 
spatere Zugriffe exakt definiert ist. Der Aufbau entspricht 
grundsatzlich dem Aufbau des Adress-Generators aus Figur 15a, 
jedoch mit der Erweiterung urn zwei Multiplexer (1522, 1523) und 
einem zusatzlichen Eintrag im, Konf igurationsregister (1523) . 
Dieser Eintrag wird im folgenden Calculate-End-Adress genannt 
und legt fest, ob die Endadresse des Datenblocks als erster 
Eintrag des Datenblocks an der durch den Base_Adressen Eintrag 
definierten Stelle abgelegt wird. Die Multiplexer werden von der 
State-Machine (1405) angesteuert . Der Multiplexer (1522) dient 
dazu die Base-Adresse oder den Ausgang des Zahlers (1509) auf das 
Tor (1515) zu schalten. Der Multiplexer (1523) schaltet entweder 
die vom Bus (1404) kommenden Daten oder den Ausgang des Zahlers 
(1509) auf das Tor (1503) . 

Figur 15c zeigt den Ablauf in der State-Machine und das Pattern 
des Speicherzugrif f s durch den in Figur 15b dargestellten Adress- 
Generator. Die State-Machine (1405) befindet sich zunachst im 
IDLE Zustand (1524). Ist der Eintrag Calculate-End-Adress im 
Konf igurationregister (1523) gesetzt, geht die State-Machine 
(1405) nach dem Schreiben der Step-Width (1529) in den Zustand 
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(1525) liber. Dort wird die Adresse fur den Zugriff auf das Ram 
aus dem Base-Adressen Eintrag in den ladbaren Auf /Ab-Zahler 
geschrieben und die Step-Width - je nach Zahler-Mode (Auf/Ab) - 
addiert oder subtrahiert. Der Ram-Zugrif f wird durchgefuhrt und 
die State-Machine geht wieder in den IDLE (1524) Zustand uber. 
Die folgenden Datentransf ers erfolgen wie durch die Base-Adressen 
und Step-Width Eintrage festgelegt. Damit sieht das Pattern im 
Speicher f olgendermaften aus. Die Base-Adresse (1526) wurde nicht 
beschrieben. Der erste Eintrag (1527) steht an der Position, die 
durch Base-Adresse plus (minus) Step-Width festgelegt wird. Die 
nachsten Eintrage (1528) folgen im Step-Width Abstand 
auf einander . 

1st das Transferende erreicht, wird ein Trigger-Signal generiert 
(1521). Aufgrund des Trigger-Signals (1521) oder eines externen 
Trigger-Signals (1417) geht die State-Machine (1405) vom IDLE- 
Zustand (1524) in den Zustand (1530) uber. Dort werden die 
Multiplexer (1522, 1523) umgeschaltet , so daft die Base-Adresse am 
Eingang von Tor (1515) anliegt und die Adresse nach dem Ende des 
Datenblocks an Tor (1503) anliegt. Danach geht die State-Machine 
(1405) in den Zustand (1531) und schreibt die Adresse nach dem 
Ende des Datenblocks an der Position der Base-Adresse ins Ram. 
Das Pattern im Speicher sieht dann f olgendermaften aus. Der 
Eintrag der Base-Adresse (1526) gibt die Adresse nach dem Ende 
des Datenblocks an. Der ersten Eintrag im Datenblock liegt an 
Adresse (1527), danach folgen die restlichen Eintrage. 
Eine weitere Ausgestaltungsmoglichkeit der State-Machine ist, daft 
aufgrund eines der Trigger-Signale (1521 oder 1417) die State- 
Machine zunachst den Zahlerstand in 1509 so korrigiert, daft 1509 
auf das letzte Datenwort des Datenblocks zeigt . Dies wird 
technisch realisiert, indem die inverse Operation zu der 
voreingestellten in 1509 durchgefuhrt wird, d.h. addiert 1509 
gemaft Voreinstellung die Step-Width, wird Step-Width nun 
subtrahiert; subtrahiert 1509 gemaft Voreinstellung, wird addiert. 
Urn die Korrektur durchzuf uhren ist in der nachfolgend in Figur 
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15c beschriebenen State-Machine ein zusatzlicher Zustand (1540) 
notwendig, urn 1509 entsprechend anzusteuern. 

Figur 16 zeigt das Zusammenspiel mehrerer Segmente bei der 
indirekten Adressierung . Das Segment n (1601) empfangt uber den 
Bus (1605) (der Ladelogikbus (1407) oder der interne Bus (1406)) 
ein Read Signal. Die Bus-IO (1603) schaltet das zugehorige Tor 
frei und erzeugt die benGtigten Kontrollsignale . Die durch 1509 
festgelegte Speicherstelle wird adressiert. Die vom Ram kommenden 
Daten (1607) werden zu Segment (n+1) (1602) geschickt. Die Ind- 
State-Machine (1604) erzeugt die benotigten Kontrollsignale und 
schickt sie ebenfalls zu Segment (n+1) (1602) . In Segment (n+1) 
(1602) passieren die Signale das in Figur 14 beschriebene Gate 
(1411) der Bus-IO (1608) . Dort wird eine Adresse fur den in Figur 
15 beschriebenen Decoder (1502) hinzugefugt, so daft der Base- 
Adressen Eintrag des Adress-Generators (1608) von Segment (n+1) 
(1602) angesprochen wird. Die von Segment n (1601) kommenden 
Daten, dienen damit als Base-Adresse in Segment (n+1) (1602), das 
heilit ein Read/Write Zugriff uber den Bus (1609) (der 
Ladelogikbus (1407) oder der interne Bus (1406)) kann diese Base- 
Adresse fur einen Zugriff auf das Ram verwenden. Der Bus (1610) 
dient zur Ubertragung der Adressen zum Ram und der Bus (1612) 
ubertragt die Daten von und zum Ram, abhangig ob ein Read oder 
Write Zugriff erfolgt. 

Figur 17 zeigt die Ind-State-Machine . Der Grundzustand ist der 
IDLE Zustand (1701) . In diesem Zustand verbleibt sie bis zum 
Eintreffen des Acknowledge Signals der State-Machine (1405) aus 
Figur 14. Danach geht die Ind-State-Machine in den Zustand Write 
(1702) uber und erzeugt ein Write Enable Signal, das mit den 
Daten zu Segment (n+1) geschickt wird. Es dient dort dazu, den 
Decoder, der die verschiedenen Eintrage auswahlt, zu aktivieren. 
Anschlieliend erfolgt der Ubergang zum Zustand Wait_f or_Ack. Nach 
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dem Acknowledge Signal des Segments (n+1) geht die Ind-State- 
Machine wieder in den IDLE (1-701) Zustand. 
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6 Begrif f sdef inition 

ADR-GATE Tor, das die Adressen auf den E-BUS auf schaltet, sofern 
der Baustein E-BUS-MASTER ist.} 

DFP Datenf luliprozessor nach Patent/Of fenlegung DE 44 16 881 

DPGA Dynamisch konf igurierbare FPGAs . Stand der Technik 

D-FlipFlop Speicherelement, welches ein Signal bei der 
steigenden Flanke eines Taktes speichert. 

EB-REG Register, das sie Statussignale ' zwischen I-BUS und E- 
BUS speichert. 

E-BUS Externes Bussystem aufrerhalb eines Bausteines. 

E-BUS-MASTER Baustein, der den E-BUS steuert. Aktiv. 

E-BUS-SLAVE Baustein, der vora E-BUS-MASTER angesprochen wird. 
Passiv. 

E-GATE Tor, das von der bausteininternen Zustandsmaschine oder 
vora E-BUS-MASTER gesteuert wird und Daten auf den E-BUS 
auf schaltet . 

E-GATE-REG Register in das die Daten eingestragen werden, die 
iiber das E-GATE auf den E-BUS ubertragen werden. 

E-READ Flag im EB-REG, das anzeigt, dall die OUTPUT-CELLs 
komplett auf den E-BUS ubertragen wurden. 

E-WRITE Flag im EB-REG, das anzeigt, daft der E-BUS kornplett in 
die INPUT-CELLs ubertragen wurde . 
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Flag (Fahne) . Statusbit in einem Register, das einen Zustand 

anzeigt . 



FPGA Programmierbarer Logikbaustein . Stand der Technik. 

Handshake Signalprotokoll, bei dem ein Signal A einen Zustand 
anzeigt und ein anderes Signal B bestatigt, daft es 
Signal A akzeptiert und darauf reagiert (hat) . 

INPUT-CELL Baugruppe, die Daten vom E-BUS auf einen I-BUS 
ubertragt . 



I-BUSn (auch I-BUS) Bausteininternes Bussystem, das auch aus 
Bundeln von einzelnen Leitungen bestehen kann. n gibt 
die Nuramer des Busses an. 



II-BUSn (auch II-BUS) Bausteininternes Bussystem, das auch aus 
Bundeln von einzelnen Leitungen bestehen kann. Der Bus 
wird von einer INPUT-CELL getrieben und geht auf 
logische Eingange. n gibt die Nummer des Busses an. 



IO-BUSn (auch IO-BUS) Bausteininternes Bussystem, das auch aus 
Biindeln von einzelnen Leitungen bestehen kann. Der Bus 
wird von logischen Ausgangen getrieben und geht an eine 
OUTPUT-CELL, n gibt die Nummer des Busses an. 

I -GATE Tor, das Daten auf den I-BUS aufschaltet. 



I-GATE-REG Register, das von der bausteininternen 

Zustandsmaschine oder vom E-BUS -MASTER gesteuert wird 
und in das die Daten eingestragen werden, die uber das 
I -GATE auf den I-BUS ubertragen werden. 
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I-READ Flag im EB-REG, das anzeigt, dafl die INPUT-CELLs 
komplett auf den I-BUS ubertragen wurden. 

I-WRITE Flag im EB-REG, das anzeigt, daft der I-BUS komplett in 
die OUTPUT-CELLs ubertragen wurde. 

Kantenzelle Zelle am Rand eines Zellarrays, oftmals mit direktem 
Kontakt zu den Anschlussen eines Bausteines. 

Konf igurieren Einstellen der Funktion und Vernetzung einer 

logischen Einheit, einer (FPGA) -Zelle (Logikzelle) oder 
einer PAE (vgl. umkonf igurieren) . 

Ladelogik Einheit zum Konf igurieren und Umkonf igurieren 

einer PAE oder Logikzelle. Ausgestaltet durch einen 
speziell an seine Aufgabe angepaliten Mikrokontroller . 

Latch Speicherelement, das ein Signal fur gewohnlich 

wahrend des H-Pegels transparent weiterleitet und 
wahrend des L-Pegels speichert. In PAEs werden 
teilweise Latches gebraucht, bei denen die Funktion der 
Pegel genau umgekehrt ist. Hierbei wird vor den Takt 
eines iiblichen Latch ein Inverter geschaltet. 

Logikzellen Bei DFPs, FPGAs, DPGAs verwendete konf igurierbare 
Zellen, die einfache logische oder arithmetische 
Aufgaben gemafi ihrer Konf iguration erfullen. 

MASTER Flag im EB-REG, das anzeigt, daft der Baustein E-BUS- 
MASTER ist. 

MODE-PLUREG Register in dem die Ladelogik die Konf iguration einer 
INPUT- /OUTPUT-CELL einstellt. 



32 



WO 98/28697 



PCT/DE97/03013 



OUTPUT-CELL Baugruppe, die Daten von einem I-BUS auf den E-BUS 
ubertragt. 

PAE Processing Array Element: EALU mit O-REG, R-REG, 

R2CA-MUX, F-PLUREG, M-PLUREG, BM-, SM-, Sync-, 
StateBack- und Power-UNIT. 

PLU Einheit zum Konf igurieren und Umkonf igurieren 

einer PAE oder Logikzelle. Ausgestaltet durch einen 
speziell an seine Aufgabe angepaliten Mikrokontroller . 

REQ-MASTER Flag im EB-REG, das anzeigt, daft der Baustein E- 
BUS-MASTER werden mochte. 

RS-FlipFlop Reset-/Set-FlipFlop. Speicherelement, das durch 2 
Signale umgeschaltet werden kann. 

SET-REG Register das anzeigt, dafi Daten in ein I-GATE-REG oder 
E-GATE-REG geschrieben und noch nicht gelesen wurden. 

STATE-GATE Tor, das den Ausgang des SET-REG auf den E-BUS 

schaltet. 

Tor Schalter, der ein Signal weiterleitet oder sperrt. 

Einfacher Vergleich: Relais 

Umkonf igurieren Neues Konf igurieren von einer beliebigen Menge 
von PAEs oder Logikzellen wahrend eine beliebige 
Restmenge von PAEs oder Logikzellen ihre eigenen 
Funktionen fortsetzen (vgl. konf igurieren) . 

Zustandsmaschine Logik, die diversen Zustanden annehmen kann. 

Die Obergange zwischen den Zustanden sind von 
verschiedenen Eingangsparametern abhangig. Diese 
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Maschinen werden zur Steuerung komplexer Funktionen 
eingesetzt und entsprechen dem Stand der Technik} 
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Patent ansprtiche 

1. Bussystem, hergestellt durch Bundelung mehrere einzelner 
Leitungen Oder Busse oder Teilbusse (vgl. Fig. 4/5) innerhalb 
eines Bausteines der Gattung DFP, FPGA, DPGA, sowie alien 
Bausteinen mit zwei- oder mehrdimensionaler programmierbare 
Zellstruktur (vgl. Fig. 1/2/3), uber welches die Bausteine zu 
Mehreren zusammengef aftt werden konnen und/oder Speicher und/oder 
Peripherie anschlieftbar ist (vgl. Fig. 10). 

2. Bussystem nach Anspruch 1, dadurch gekennzeichnet , daft eine 
Oder mehrere Schnittstellen (Fig. 6/7) die Zusammenf assung der 
Leitungen ubernehmen und das Bussystem erzeugen. 

3. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
eine oder mehrere Zustandsmaschine (n) (0703/0603) die 
Schnittstellen (vgl. Fig. 6/7) steuert/steuern . 

4. Bussystem nach Anspruch 1, 2 und 3, dadurch gekennzeichnet, 
daft 

die Zustandsmaschine auch den externen Bus steuert. 

5. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, 
daft daft ein Adressgenerator existiert (0610/0710) , der die 
Adressen fur' die uber den Bus zu kontaktierenden Bausteine 
generiert . 

6. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, 
daft 

die Schnittstellen ein internes Bussystem oder mehrere interne 
Bussysteme, das/die aus mehreren Leitungen zusammengef aftt sein 
kann/konnen (vgl. Fig. 4/5), zum Schreiben und Lesen verwendet 
(vgl. Fig. 9a, I-BUS) . 
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7. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet , daft 
die Schnittstellen ein internes Bussystem oder mehrere interne 
Bussysteme, das/die aus mehreren Leitungen zusammengef aftt sein 
kann/konnen (vgl. Fig. 4/5), entweder zum Schreiben oder Lesen 
verwendet (vgl. Fig. 9b, II-BUS, IO-BUS). 

8. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
die Schnittstellen ein internes Bussystem oder mehrere interne 
Bussysteme, das/die aus mehreren Leitungen zusammengef aftt sein 
kann/konnen (vgl. Fig. 4/5), nach Anspruch 6 und 7 gemischt 
betreiben. 

9. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
ein Register zur Verwaltung und Steuerung des Bussystems 
existiert (EB-REG, 0702, 0602). 

10. Bussystem nach Anspruch 1, und 2, dadurch gekennzeichnet, dali 
die Bussteuerung durch einen Baustein (E-BUS -MASTER) erfolgt, der 
auf eine Vielzahl von untergeordneten Bausteinen (E-BUS-SLAVE) 
zugreif t . 

11. Bussystem nach Anspruch 1, 2 und 10, dadurch gekennzeichnet, 
dali 

die Bussteuerung dynamisch von einem Baustein (E-BUS -MASTER) an 
einen anderen iibergeben wird (MASTER-Eintrag im EB-REG) . 

12. Bussystem nach Anspruch 1, 2, 10 und 11, dadurch 
gekennzeichnet, daft 

ein untergeordneter Baustein (E-BUS-SLAVE) den Erhalt der 
Buskontrolle fordern kann (REQ-MASTER-Eintrag im EB-REG) . 

13. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
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ein Register existiert, das anzeigt, ob Daten in den 
Schnittstellen gespeichert sind (SET-REG, 0612, 0712). 

14. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
die Schnittstellen entweder direkt auf dem Baustein implementiert 
sind, oder durch die Konf iguration von Logikzellen, das sind 
Zellen in DFP-, FPGA-, DPGA, oder ahnlichen Bausteinen, die 
einfache logische oder arithmetische Aufgaben gemaft ihrer 

Konf iguration erfullen, entstehen. 

15. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
die Schnittstellen von einer Ladelogik und/oder dem Baustein 
selbst (vgl. Fig. 8/11) konfiguriert werden konnen. 

16. Bussystem nach Anspruch 1, 2 und 15, dadurch gekennzeichnet, 
daft 

die Ladelogik partiell auf dem Baustein integriert ist. 

17. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
Standardbussysteme eingesetzt werden konnen (vgl. Fig. 12). 

18. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
der Baustein weitere gewohnliche Anschlusse nach bei DFPs, FPGAs, 
DPGAs , o.a. ublicher Art besitzt (vgl. Fig. 12 1201, 1204). 
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